home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c15 / MultiJabberServer.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.1 KB  |  117 lines

  1. //: MultiJabberServer.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // A server that uses multithreading to handle 
  50. // any number of clients.
  51. import java.io.*;
  52. import java.net.*;
  53.  
  54. class ServeOneJabber extends Thread {
  55.   private Socket socket;
  56.   private BufferedReader in;
  57.   private PrintWriter out;
  58.   public ServeOneJabber(Socket s) 
  59.       throws IOException {
  60.     socket = s;
  61.     in = 
  62.       new BufferedReader(
  63.         new InputStreamReader(
  64.           socket.getInputStream()));
  65.     // Enable auto-flush:
  66.     out = 
  67.       new PrintWriter(
  68.         new BufferedWriter(
  69.           new OutputStreamWriter(
  70.             socket.getOutputStream())), true);
  71.     // If any of the above calls throw an 
  72.     // exception, the caller is responsible for
  73.     // closing the socket. Otherwise the thread
  74.     // will close it.
  75.     start(); // Calls run()
  76.   }
  77.   public void run() {
  78.     try {
  79.       while (true) {  
  80.         String str = in.readLine();
  81.         if (str.equals("END")) break;
  82.         System.out.println("Echoing: " + str);
  83.         out.println(str);
  84.       }
  85.       System.out.println("closing...");
  86.     } catch (IOException e) {
  87.     } finally {
  88.       try {
  89.         socket.close();
  90.       } catch(IOException e) {}
  91.     }
  92.   }
  93. }
  94.  
  95. public class MultiJabberServer {  
  96.   static final int PORT = 8080;
  97.   public static void main(String[] args)
  98.       throws IOException {
  99.     ServerSocket s = new ServerSocket(PORT);
  100.     System.out.println("Server Started");
  101.     try {
  102.       while(true) {
  103.         // Blocks until a connection occurs:
  104.         Socket socket = s.accept();
  105.         try {
  106.           new ServeOneJabber(socket);
  107.         } catch(IOException e) {
  108.           // If it fails, close the socket,
  109.           // otherwise the thread will close it:
  110.           socket.close();
  111.         }
  112.       }
  113.     } finally {
  114.       s.close();
  115.     }
  116.   } 
  117. } ///:~